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(57) Abstract 

The invention relates to a method and ar- 
rangement for calculating correlation between a 
first and a second code sequence, which comprise 
a number of samples and have a finite length, 
which arrangement comprises means (205) for 
estimating the delay between the code sequences 
and means (206) for setting the codes to a desired 
phase with respect to each other on the basis of 
the delay between the code sequences by rotating 
the first sequence. To allow correlation to be cal- 
culated quickly and simply the arrangement com- 
prises means (210) for comparing the sequences 
with each other in parallel mode sample by sam- 
ple and means (212, 214) for adding the results 
of the sample-specific comparisons together. 
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Method and arrangement for calculating correlation 

FIELD OF THE INVENTION 

A method for calculating correlation between a first and a second 
code sequence, which are previously known code sequences used in 
5 telecommunications systems, comprise a number of samples and have a finite 
length, and in which method the delay between the code sequences is 
calculated and the codes are set to a desired phase with respect to each other 
on the basis of the delay between the code sequences by rotating the first 
sequence. 

1 0 BACKGROUND OF THE INVENTION 

The present invention can be used for calculating 
auto/crosscorrelations between finite length sequences. The disclosed. method 
and arrangement are applicable to any situation in which said correlations are 
to be calculated. The method can be particularly preferably applied to data 

15 transmission systems utilizing a direct sequence code division multiple access 
(DS-CDMA) method, in which systems correlations need to be calculated 
between differently delayed codes. 

In the DC-CDMA the user's narrow-band data signal is modulated 
to a relatively wide band with a spreading code having a broader band than 

20 the data signal. In the used systems band widths from 1.25 MHz to 50 MHz 
have been employed. A spreading code usually consists of a long pseudo- 
random bit sequence. The bit rate of the spreading code is much higher than 
that of the data signal, and to distinguish it from data bits and data symbols the 
bits of the spreading code are called chips. The data symbol of each user is 

25 multiplied by all chips of a spreading code. The narrow-band data signal thus 
spreads to the frequency band utilized by the spreading code. Each user has a 
spreading code of his own. Several users simultaneously transmit over the 
same frequency band, and data signals are distinguished from one another in 
the receivers on the basis of the pseudo-random spreading code. However, 

30 different users 1 signals interfere with one another in the receiver, since the 
spreading codes are not completely orthogonal especially due to the phase 
shift caused by propagation delay. 

In the CDMA systems the multiple access interference is reduced 
e.g. by means of multi-user detection (MUD) or interference cancellation 

35 methods. There are several such methods, but it is common to them that they 
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need input information on the correlations between the outputs of the received 
signal. 

According to the prior art, correlations between finite length 
sequences are typically calculated in serial mode one symbol at a time by 
5 using shift-register-based arrangements and by transmitting the sequence in a 
register forward between the calculations. The most significant drawback of 
the serial mode processing is its slowness, which becomes particularly 
apparent in telecommunications applications. 

BRIEF DESCRIPTION OF THE INVENTION 

10 An object of the present invention is to provide a method for 

calculating correlation, which allows calculation to be performed quickly with a 
simple arrangement. 

This is achieved with the method described in the introduction, 
characterized in that the correlation between the sequences is calculated by 

15 comparing the sequences with each other sample by sample in parallel mode, 
and by adding the results of the sample-specific comparisons together. 

The invention further relates to an arrangement for calculating 
correlation between a first and a second sequence, which are previously 
known code sequences used in telecommunications systems, comprise a 

20 number of samples and have a finite length, and which arrangement 
comprises means for estimating the delay between the code sequences and 
means for setting the codes to a desired phase with respect to each other on 
the basis of the delay between the code sequences by rotating the first 
sequence. The arrangement of the invention is characterized in that the 

25 arrangement comprises means for comparing the sequences with each other 
sample by sample in parallel mode, and means for adding the results of the 
sample-specific comparisons together. 

The method and arrangement of the invention have several 
advantages. The correlation calculation implemented in parallel mode 

30 according to the invention is fast. The method can also be applied to cases in 
which the sequences to be correlated are of different lengths. When the 
invention is applied in telecommunications systems, the users' transmission 
rates may differ from one another. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

In the following, the invention will be described in greater detail with 
reference to the examples of the accompanying drawings, in which 

Figure 1 illustrates an example of a data transmission system to 
5 which the solution of the invention can be applied, 

Figure 2 generally illustrates the solution of the invention, 

Figure 3 illustrates an example of sequences in different phases 
with respect to one another, 

Figure 4 illustrates an example of the arrangement according to the 
10 invention, and 

Figure 5 illustrates an example of a CDMA receiver in which the 
solution of the invention is applied. 

DETAILED DESCRIPTION OF THE INVENTION 

In general, the invention can be used for calculating correlation 

15 between two sequences. The solution of the invention can be particularly 
preferably applied to radio systems utilizing the DS-CDMA, typically to cellular 
radio systems. In the following, the invention will be described by way of 
example in connection of cellular radio systems, without limiting the invention 
thereto. The disclosed principles of the invention can be easily applied in other 

20 connections, as will be clear to one skilled in the art. 

Figure 1 illustrates one cell of the CDMA system by way of 
example. Each cell of the system typically comprises one base station 100, 
which is in contact to the subscriber terminals 102 to 106 which are within its 
area and which can be either mobile or fixed equipment. Each subscriber 

25 terminal 102 to 106 transmits and receives a signal 108 to 112 together with 
the base station. Each transmission is sent over the same frequency band, 
and the transmissions are distinguished from one another by means of 
spreading sequences which are different for each connection and by which the 
information to be transmitted has been multiplied. 

30 Both the receiver of the terminal and the receiver of the base station 

receive a composite signal which not only comprises the desired signal but 
also other signals. When advanced methods of reception are utilized, such as 
interference cancellation or multi-user detection, there is need for calculating 
correlation between differently delayed codes. 
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Figure 2 generally illustrates the solution of the invention for 
calculating correlation. The input comprises two code sequences 200, 202 and 
the delay 204 between them. In the CDMA application it can be assumed that 
the sequence 202 is the desired user's sequence, and the sequence 200 is 
5 the interfering user's spreading code sequence. The sequences can be 
supplied to correlation calculation means e.g. from the memory means (not 
shown). The sequences are first supplied to preprocessing means 206, 208. 
The code sequence is set to the desired phase on the basis of the delay 
difference between the sequences, which delay difference 204 is input to the 

10 preprocessing means 206 from calculation means 205. The input 207 of the 
calculation means 205 comprises the delays of the codes 200, 202 with 
respect to a given reference. The desired phase can be provided e.g. by 
rotating the sequence in a register until the correct phase is achieved. In 
practice, rotation can also be implemented by means of a barrel shifter, which 

15 comprises multiplexers by means of which the sequence can be directly 
rotated to the correct phase without shift registers. In that case the time 
needed for rotating the sequence is constant. If desired, oversampling can 
also be performed in the preprocessing means e.g. in order to estimate the 
wave form. 

20 Next phasing of code sequences will be described in greater detail 

by means of the example shown in Figure 3. The figure shows two short code 
sequences 200, 202, which both are only four chips long for the sake of clarity. 
It is assumed that the sequences are the above-mentioned spreading codes of 
different users, and their measured delay difference is one symbol. In that 

25 case one sequence 200 is rotated so that its phase to the other sequence 202 
is one chip long, i.e. according to the figure, the first chip '0' of the sequence 
200 is at chip '1' of the other sequence 202. As a result of the rotation, the last 
chip '3' of the first sequence is at the first chip '0' of the second sequence 202. 
In the CDMA system the situation described above in practice means that the 

30 last chip '3' of the first sequence 200 is the last spreading code chip of the 
sequence used for multiplying the previous information symbol. In other words, 
the symbols partially overlap due to the delay. 

We shall now return to Figure 2. The phased sequences are 
supplied to comparison means which calculate the correlation between the 

35 sequences by comparing the sequences in parallel mode with one another 
sample by sample, i.e. the first sample of each sequence is compared with the 
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sample of another sequence in the same position. The results obtained in the 
comparison are fed into the adder, the number of which may vary from one to 
two, depending on the implementation. The figure illustrates two adders 212 
and 214. From the adders the result is supplied to scaling means 216, 218, in 
5 which the correlation result can be normalized to a desired area. One adder is 
used when one is interested only in the overlapping parts of a sequence, 
whereas two adders are used when one wants to obtain information on the 
partially overlapping symbols described above. The latter method is usually 
applied in CDMA applications. Alternatively, the summations required by the 

10 CDMA could be performed one after another with the same adder, provided 
that the delay caused is not detrimental. The scaled correlation results 220, 
222 obtained from the scaling means 216, 218 are supplied to further 
utilization. In scaling, the modulation method and the size of the area to be 
examined are taken into account. 

1 5 In the following, a preferred embodiment of the invention will be 

described in greater detail. The most straightforward way of calculating the 
correlation between the sequences is to multiply the sequences by each other 
sample by sample and to add the results together. Since the multiplication is 
complicated to carry out, a XOR function is used in the solution of the 

20 invention for measuring the equivalence between the sequences. The XOR 
function operates according to the table illustrated below as a parameter of 
two operators OP1, OP2 as follows: if the operators have the same value, the 
result is '0', and if the values are different, the result is T. 



OP1 


OP2 


Result 


0 


0 


0 


0 


1 


1 


1 


0 


1 


1 


1 


0 



25 

In the solution of the invention, the correlation of two sequences is calculated 
in such a manner that a XOR sum is calculated for the samples in the same 
position, and the equivalences (value 0) and the deviations (value 1) obtained 
are added together. The correlation between the sequences is obtained by 
30 subtracting the number of deviations from the numDer of equivalences. In 
practice, the calculation can be further simplified. A XOR sum is calculated for 
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the chips in the same position, and the deviations obtained are added 
together. The correlation is obtained from this by subtracting the number of 
deviations multiplied by two from the number of chips (i.e. the size of the 
correlation area). 

5 Next we shall take a look at an example of two code sequences, s k 

and s m , both of which are four bits long: 

s k = 0 1 0 1 
s m = 1 0 0 0. Then 
s k XORs m = 110 1. 
10 The number of deviations (value 1) is 3. This yields the unsealed correlation 
value 4 - 2*3 = -2. 

In the following, another preferred embodiment of the method of the 
invention will be described. This can be used when one wants to obtain 
information on the above-mentioned partially overlapping symbols. First, we 
15 shall examine Figure 3 again. The figure shows two short code sequences 
200, 202 the measured delay difference of which is one symbol. Correlation 
calculation is divided into two parts on the basis of the delay between the 
sequences. Since different information symbols partially overlap due to the 
delay, correlations R1, R2 are calculated separately for these symbols. The 
20 first part 300 comprises the sample pairs which precede the first symbol '0' of 
the rotated sequence (the figure shows only one sample pair). The other part 
302 comprises the sample pairs which follow the first symbol '0' of the rotated 
sequence, said symbol being included. The division is based on the boundary 
of the information symbols of the rotated code sequence. In the figure there 
25 are three such sample pairs. The calculation of deviations described above is 
performed separately on these parts by means of the XOR sum. 

Next we shall take a look at an example. The same two code 
sequences, s k and s m , which were discussed above will be used. In this case 
the delay between them is 1. The sequence s m has been rotated by one bit, 
30 and the symbol boundary is between the first and the second bit: 

s k = 0 1 1 0 1 
s m = 0 1 1 0 0. Then 
s k XORs m = 0100 1. 
In the first part, which consists of only one bit, the number of deviations (value 
35 1) is zero, and thus the value of correlation R1 is 1 - 2*0 = 1. In the second 
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part the number of deviations (value 1) is 1 . Thus the value of correlation R2 is 
3-2*1 = 1. 

In the following, the arrangement implementing the method 
explained above will be described. This arrangement is illustrated in Figure 4. 
5 The input comprises the values of sample pairs 400 to 404, which are supplied 
to a number of XOR gates 406 to 410. The outputs of the gates are supplied 
to the demultiplexing gates 412 to 416, from which the outputs of the counters 
are supplied either to the adder 424 of the first part or to the adder 426 of the 
second part, depending on which part the sample pair at the input of each 

10 counter belongs to. The output of the counting means 422 functions as the 
second input of the demultiplexing gates 412 to 416, which guides the 
demultiplexing gates. The delay 420 between the sequences is input to the 
counting means 422, which on the basis of the input calculate to which adder 
means the output of each XOR gate should be directed. The outputs of the 

15 adder means are supplied to the corresponding counters 428, 430, which 
calculate correlations for the parts on the basis of the sum information. The 
delay information 420 is also supplied to the counters; it is fed directly into the 
counter 428 of the first part, and through the gate 432 as two's complement 
into the counter 430 of the second part. 

20 The calculation components described above can be implemented 

as such by using known components. The number of summation counters can 
be reduced to one, if so desired, provided that the sums of the different parts 
are calculated in sequence. This allows to simplify the arrangement, whereas 
the calculation delay increases. 

25 In the following, a CDMA receiver to which the solution of the 

invention is applied will be described by way of example. The block diagram in 
Figure 5 illustrates the structure of the receiver. The receiver comprises an 
antenna 500 which receives a broadband signal which comprises summed 
signal components from various transmitters. A received signal is supplied to 

30 the radio frequency parts 502 which convert it to the base band. The 
converted signal is further fed into the sampling means 504 which convert the 
signal to a digital form. The converted signal is applied to the delay estimation 
block 506 in which delay differences between different signal components are 
estimated. The delay estimates 520 are supplied to the correlation means 508 

35 which by utilizing the method of the invention calculate the correlations 
between the signals on the basis of the information on the delay difference. 
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The delay estimates 520 and the converted signal are also supplied to the 
despreading means 510, which convert the signal to a narrow-band form. The 
output of the despreading means 510 is supplied both to the decision means 
512 which make the conventional symbol decision, and interference removal 
5 means 514 to which the correlation results 518 and preliminary symbol 
decisions are supplied from the decision means 512. The interference 
cancellation means cancel interference and their output signal 516 is supplied 
further to the other parts of the receiver for final detection. 

Even though the invention has been described above with 
10 reference to the examples according to the accompanying drawings, it is clear 
that the invention is not restricted thereto, but it can be modified in several 
ways within the scope of the inventive idea disclosed in the appended claims. 
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CLAIMS 

1. A method for calculating correlation between a first (200) and a 
second (202) code sequence, which are previously known code sequences 
used in telecommunications systems, comprise a number of samples and 

5 have a finite length, and in which method a delay between the code 
sequences is calculated and the codes are set to a desired phase with respect 
to each other on the basis of the delay between the code sequences by 
rotating the first sequence, characterized in that the correlation 
between the sequences is calculated by comparing the sequences with each 
10 other in serial mode sample by sample, and by adding the results of sample- 
specific comparisons together. 

2. A method as claimed in claim ^characterized in that the 
samples of the sequences are binary symbols, and the sequences are 
compared with each other by calculating the number of deviations of the 

15 samples in the same position and by subtracting the number of deviations 
multiplied by two from the size of the correlation area. 

3. A method as claimed in claim 2, characterized in that on 
calculating the equivalences of the samples, the samples (300) from the 
beginning of the second sequence to the beginning of the unrotated first 

20 sequence, and the samples (302) from the beginning of the first unrotated 
sequence to the end of the second sequence are calculated and summed 
separately. 

4. A method as claimed in claim 3, characterized in that the 
comparisons to be carried out separately in parallel mode are performed in 

25 sequence in serial mode. 

5. A method as claimed in claim 1, characterized in that 
oversampling is performed on the sequences before the comparison. 

6. A method as claimed in claim ^characterized in that the 
sequences to be compared are of different lengths. 

30 7. A method as claimed in claim ^characterized in that the 

code sequences are used as different users 1 spreading codes in CDMA data 

transmission systems. 

8. An arrangement for calculating correlation between a first and a 

second code sequence, which are previously known code sequences used in 
35 telecommunications systems, comprise a number of samples and have a finite 

length, which arrangement comprises means (205) for estimating the delay 
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between the code sequences and means (206) for setting the codes to a 
desired phase with respect to each other on the basis of the delay between 
the code sequences by rotating the first sequence, characterized in 
that the arrangement comprises means (210) for comparing the sequences 
5 with each other in parallel mode sample by sample and means (212, 214) for 
adding the results of the sample-specific comparisons together. 

9. An arrangement as claimed in claim 8, characterized in 
that the means (210) comprise means (406 to 410) for detecting deviations of 
the samples in the same position. 

10 1 0. An arrangement as claimed in claim 9, characterized in 

that the arrangement comprises means (422, 412 to 216, 424) for calculating 
the deviations of the samples from the beginning of the second sequence to 
the beginning of the unrotated first sequence and means (422, 412 to 216, 
426) for calculating the deviations of the samples from the beginning of the 

15 unrotated first sequence to the end of the second sequence and means (428, 
430) for calculating the corresponding correlations. 

1 1 . An arrangement as claimed in claim 8, characterized in 
that the arrangement comprises means (206, 208) for performing 
oversampling on the sequences before the comparison. 



WO 98/17026 



PCT/F197/00624 



1/3 



Y 



112 



102 



MS 





X < ~y^ X 

110 i— i 



104 



MS 

37 



100 



BS 

37 



Y 



106 



MS 



Fig. 1 



207 



V 



EST — t 

205-^ 'J 
204 



200 



206 



ROT&SAMP 



I 



212 



SUM 



216 



SCA 



V 



202 

v r 



208 



SAMP 



•210 



CALC 



] [ 



220 



v r 



214 



SUM 



218 



SCA 



V 



222 



Fig. 2 



WO 98/17026 



PCT/FI97/00624 



2/3 




D) 

• — 

LL 



WO 98/17026 



3/3 



PCT/FI97/00624 



202 



V 



200 











0 


1 


2 


3 


1 


3 


0 


1 


2 



300 



— on 



I 

! 
I 
I 

i 

302 



Fig. 3 



500 



v 



502 



504 r 506 r 508 



518 




510 



512 



514' 



516 



Fig. 5 



